import requests
import json
import sys
import time

# Disable warnings for SSL Certificate (avoid in production if possible)
requests.packages.urllib3.disable_warnings()

# BMC Configuration
bmc_ip = "your_bmc_ip"
bmc_user = "your_bmc_user"
bmc_pass = "your_bmc_pass"

# Redfish Base URLs
redfish_base_url = f"https://{bmc_ip}/redfish/v1"
session_service_url = f"{redfish_base_url}/SessionService/Sessions"
systems_url = f"{redfish_base_url}/Systems"

# Function to handle Redfish requests with retries
def redfish_get(url, headers, max_retries=3, retry_delay=2):
    for attempt in range(max_retries):
        try:
            response = requests.get(url, headers=headers, verify=False)
            response.raise_for_status()  # Raise an exception for HTTP errors
            return response.json()
        except requests.exceptions.RequestException as e:
            if attempt < max_retries - 1:  # Retry if not the last attempt
                print(f"Error fetching {url}: {e}. Retrying in {retry_delay} seconds...")
                time.sleep(retry_delay)
            else:
                raise  # Raise the exception if all retries fail

# Create Redfish Session and get X-Auth-Token
session_payload = {"UserName": bmc_user, "Password": bmc_pass}
try:
    response = requests.post(session_service_url, json=session_payload, verify=False)
    response.raise_for_status()
    auth_token = response.headers.get("X-Auth-Token")
    session_location = response.headers.get("Location")
except requests.exceptions.RequestException as e:
    print(f"Failed to create Redfish session: {e}")
    sys.exit(1)

auth_headers = {"X-Auth-Token": auth_token}

# Get System Information
try:
    systems_data = redfish_get(systems_url, auth_headers)
    print(json.dumps(systems_data, indent=4))  # Debugging: print system information
except requests.exceptions.RequestException as e:
    print(f"Failed to get system information: {e}")
    sys.exit(1)

# Check if systems_data has a valid Members key and path
if "Members" not in systems_data or not systems_data["Members"]:
    print("No systems found in response.")
    sys.exit(1)

# Find the relevant system (assuming the first one for now)
system_url = systems_data["Members"][0]["@odata.id"]
print(f"Using system URL: {system_url}")

# Modify system URL in case the embedded path is wrong
# In some cases, 'System.Embedded.1' might not exist, trying 'System.1' as a fallback
if "System.Embedded" in system_url:
    system_url = system_url.replace("System.Embedded", "System")

# Fetch full system details to find correct storage path
try:
    system_data = redfish_get(f"{redfish_base_url}{system_url}", auth_headers)
    print(json.dumps(system_data, indent=4))  # Debugging: print full system data
except requests.exceptions.RequestException as e:
    print(f"Failed to get system details: {e}")
    sys.exit(1)

# Get Storage Information for the system
try:
    storage_url = f"{redfish_base_url}{system_url}/Storage"
    storage_data = redfish_get(storage_url, auth_headers)
    print(json.dumps(storage_data, indent=4))  # Debugging: print storage data
except requests.exceptions.RequestException as e:
    print(f"Failed to get storage information: {e}")
    sys.exit(1)

# Iterate through Storage Controllers and count RAID controllers
raid_count = 0
for storage_controller in storage_data.get("Members", []):
    controller_url = storage_controller["@odata.id"]
    try:
        controller_data = redfish_get(f"{redfish_base_url}{controller_url}", auth_headers)
        if "RAID" in controller_data.get("Name", ""):  # Basic RAID detection
            raid_count += 1
    except requests.exceptions.RequestException as e:
        print(f"Failed to get controller details: {e}")

# Evaluate RAID configuration
if raid_count == 1:
    print("Exactly one RAID disk found. Proceeding with the installation.")
elif raid_count == 0:
    print("No RAID disk found. Failing the task.")
    sys.exit(1)
else:
    print(f"Multiple RAID disks found: {raid_count}. Failing the task.")
    sys.exit(1)

# Delete the Redfish Session
try:
    delete_response = requests.delete(session_location, headers=auth_headers, verify=False)
    delete_response.raise_for_status()
    print("Session deleted successfully.")
except requests.exceptions.RequestException as e:
    print(f"Failed to delete session: {e}")
